package com.sxj.corejava.code17_模板模式;

import java.util.Arrays;

/**
 * 定义一个数组的排序方法,根据实际传递的数组类型不同,排序的规则也不同
 * 定义时只定义排序规则,不做具体实现。在调用时,使用匿名内部类做具体的实现
 * 例如:如果传递的是数字,则根据数值大小进行降序排序。如果传递的是字符串,根据字符串长度进行升序排序
 */
public abstract class SortUtil {

    public static void main(String[] args) {
        int[] arr = {6, 2, 9, 14, 1, 8, 3};
        SortUtilDesc desc = new SortUtilDesc();
        desc.sort(arr);
        System.out.println(Arrays.toString(arr));

    }

    public int[] sort(int[] arr) {
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                int result = compareTo(arr[j], arr[j + 1]);
                if (result > 0) {
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
        return arr;
    }

    public abstract int compareTo(int i, int j);

}

class SortUtilDesc extends SortUtil {

    @Override
    public int compareTo(int i, int j) {
        return j - i;
    }
}
